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(54) Agent vectoring 

(57) An ACD system (101) is programmable by an 
operator of the ACD system to automatically change the 
work of a call center agent (106-108) in order to maxi- 
mize the agent's productivity and to provide a variety of 
work balanced with "breather" time in order to prevent 
agent burn-out. The conditions for changing the agent's 
work and the agent's alternative duties when the condi- 
tions are met are both programmed by the operator via 
a vectoring capability (150) of the ACD system and a 
scripting language for defining the vectors. When an 



agent becomes available to handle a call from a partic- 
ular call queue (121-129), the agent's corresponding 
vector is executed, and the conditions specified by the 
vector are checked against the present status of the call 
center to determine if they are met. If the conditions are 
not met, the agent is caused to handle a call from the 
particular call queue. But if the conditions are met, the 
agent is caused to perform a function specified by the 
vector, other than handing a call from the particular call 
queue, even though a call may be waiting for an avail- 
able agent in that call queue. 
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Description 

T chnical Fi Id 

This invention relates to automatic call distribution s 
(ACD) systems, also variously referred toas call centers 
or telemarketing systems. 

Background of the Invention 

10 

ACD systems distribute calls -- whether inbound or 
outbound -- for handling to any suitable ones of available 
call-handling agents according to some predefined cri- 
teria. In many existing systems, such as the Lucent 
Technologies Definity® ACD system, the criteria for is 
handling the call from the moment that the ACD system 
becomes aware of the call until the call is connected to 
an agent are customer-specifiable (i.e., programmable 
by the operator of the ACD system) via a capability 
called call vectoring. Normally in present-day ACD sys- 20 
terns, when the ACD system's controller detects that an 
agent has become available to handle a call, the con- 
troller identifies all predefined call-handling skills of the 
agent (usually in some order of priority) and delivers to 
the agent the highest-priority oldest-waiting call that 25 
matches the agent's highest-priority skill. Generally the 
only condition that results in a call not being delivered 
to an available agent is that there are no calls waiting to 
be handled. 

Agents' skill priorities do not change based on ex- 30 
isting call conditions. Consequently, it is common for an 
agent to get a higher-priority call that has just arrived 
even if another call that the agent has the skill to handle 
has been waiting, and to keep getting calls of that high- 
er-priority one after another for as long as they are avail- 35 
able. This can contribute to a great disparity of waiting 
times between calls requiring different agent skills. It al- 
so contributes to agent bum-out caused by a lack of va- 
riety of calls handled by the agent. 

Present-day call-center-management toojs enable 40 
a call-center supervisor to monitor the call center, decide 
what each agent should be doing, and change the sys- 
tem accordingly. However, the supervisor normally must 
effect the change manually, or even by requesting the 
agent to itself effect the change by changing its work 45 
modes. This is a time-consuming and inefficient proce- 
dure. 

Summary of the Invention 

so 

This invention is directed to solving these and other 
problems and disadvantages of the prior art. Illustrative- 
ly according to the invention, thcro is provided a method 
and an apparatus that automatically changes a call cent- 
er agent's work in order to maximize the agent's produc- ss 
tivity and to provide a variety of work balanced with 
"breather" time in order to prevent agent burn-out. The 
conditions for changing the agent's work and the agent's 



alternative duties are operator-programmable via a vec- 
toring capability and a scripting language for defining 
the vectors. 

Generally according to the invention, an operator of 
a call center is enabled to programmably specify any 
one of a plurality of conditions that is selected by the 
operator. Then in response to an agent becoming avail- 
able to handle a call while a call is waiting to be handled 
by an available agent, a determination is made of wheth- 
er a present state of the call center satisfies the condition 
that has been programmably specified by the operator 
In response to a determination that the condition is one 
of (a) satisfied and (b) not satisfied, the available agent 
is caused to handle the waiting call. But in response to 
a determination that the condition is the other of (a) sat- 
isfied and (b) not satisfied, the available agent is caused 
to perform a function other than handling the waiting call 
-- taking a breather from handling calls, for example. 
Preferably, the operator programmably specifies not on- 
ly the condition but also the function that is the agent's 
alternative to handling the waiting call, and preferably 
the operator programmably specifies the condition and 
the function individually for each agent. Preferably, the 
specification is performed by means of an agent vector 
for each agent, which vector is executed when the cor- 
responding agent becomes available to handle a call. 
The agent vector may comprise a plurality of vector 
steps each specifying a different condition and function 
and also specifying -- either explicitly or implicitly -- 
whether, and which, other vector step or steps are to be 
executed if the condition specified by the presently-ex- 
ecuting step is not satisfied, and the function specified 
by the presently-executing vector step is assigned to the 
agent if the condition specified by the presently-execut- 
ing vector step is satisfied. 

Consequently, an agent who becomes available to 
handle a call is automatically assigned work whose se- 
lection is based upon the present state of the call center 
(which state may include either the call center's or the 
agent's own present history) and not just upon whether 
or not a call is waiting for the agent. Moreover, the se- 
lection of the work is programmable by an operator of 
the call center rather than being fixed, and hence is flex- 
ible and adaptable to each operator's needs. 

Illustratively, the invention may be used to imple- 
ment the following advantageous scenarios: 

Depending on the call queue conditions or the 
agent's occupancy rates, agents can be given a var- 
iable-length breather between answering calls (e. 
g., by being placed in "after call work" state, ACW) 
or they can be automatically put in "Auxiliary" work 
state with reason code (e.g. , "doing mail"), either for 
a timed period or in a "wait for agent action" mode. 
Agents can also be given music during this time 
away from calls. 
• Agents can backup other skills only if the call 
queues are in trouble or during certain times of day. 
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Today, supervisors and others who backup agents 
have to monitor the call queues and log in when traf- 
fic spikes occur. With agent vectoring, this can be 
done automatically by creating agent vectors that 
only assign agents to handle calls when call queues 
reach a certain occupancy level and stop automat- 
ically when queues fall below that occupancy level. 

• Breaks can be automatically programmed in the 
agent vector based on the time-of-day and number 
of agents presently on break. 

• Agents can control how much time they spend on a 
particular skill by setting a ceiling on the number of 
calls they handle or the amount of time they will 
spend on handling calls. Agents can dedicate a per- 
centage of their time to each of their skills. This can 
also be used to force a variety of calls to be sent to 
an agent. 

• Employee work-time scheduling packages can do 
a better job of scheduling agents with multiple skills 
by dedicating a percentage of the agents' time to 
each of their skills. 

• Agents' preferences may be determined and given 
effect by the ordering of vector command steps : not 
merely by the agents' level of expertise. 

• Announcements and tones can be played to agents 
(e.g., "take a break", "overload", "back to work") 
based on what is happening in the call center. 

• Vectors can be chained together by using a "goto 
agent vector" command for continued vector 
processing, or agents can be removed from a vec- 
tor's processing by using a "route to agent vector" 
command to interrupt the present vector process- 
ing. 

• Special "execute once" vectors can be used by 
service observers to give agents immediate feed- 
back. For example, if an agent did a good job, an 
announcement could be played to the agent con- 
gratulating the agent, followed by a break. But if the 
agent did a poor job, the agent could be routed to 
the observer for immediate consultation. 

These and other advantages and features of the 
present invention will become more apparent from the 
following description of an illustrative embodiment of the 
invention taken together with the drawing. 

Brief Description of the Drawing 

FIG. 1 is a block diagram of a call center that in- 
cludes an illustrative embodiment of the invention; 
FIGS. 2-12 are functional flow diagrams of illustra- 
tive commands that are used to implement agent 
vectors of the ACD system of the call center of FIG. 
1; 

FIGS. 1 3-23 are functional flow diagrams of illustra- 
tive conditions that are used to implement the agent 
vectors of the ACD system of the call center of FIG. 
1 ; and 



FIG . 24 is a functional flow diagram of an implemen- 
tation of an illustrative agent vector of the ACD sys- 
tem of the call center of FIG. 1. 

s D tailed Description 

FIG. .1 shows an illustrative call center. As is con- 
ventional, the call center comprises a plurality of tele- 
phone lines and/or trunks 100 selectively interconnect- 

io ed with a plurality of agent positions 1 02-1 04 via an ACD 
system 101. Each agent position 102-104 includes a 
voice-and-data terminal 1 05 for use by a corresponding 
agent 106-108 in handling calls. Terminals 105 are con- 
nected to ACD system 101 by a voice-and-data trans- 

*s mission medium 1 09. Also, included in ACD system 101 
is a conventional basic call management system (BC- 
MS) and connected to ACD system 101 is a convention- 
al call management system (CMS) 110 that gather call 
records and call-center statistics for use in managing the 

20 call center and in generating call-center reports. CMS 
and BCMS will hereafter be referred to jointly as CMS 
110. 

ACD system 101 is illustratively the Lucent Tech- 
nologies Definity® private-branch exchange (PBX)- 

25 based ACD system. It is a storcd-program-controllcd 
system that conventionally includes interlaces to exter- 
nal communications links, a communications switching 
fabric, service circuits (e.g., tone generators, announce- 
ment circuits, etc.), memory for storing control programs 

30 and data, and a processor for executing the stored con- 
trol programs to control the interfaces and the fabric and 
to provide automatic call-distribution functionality. In- 
cluded among the data stored in ACD system 101 are 
a set of call queues 1 20 and a set of agent queues 1 30. 

35 Each call queue 121-129 corresponds to a different 
agent skill, as does each agent queue 131-139. Con- 
ventionally, calls are prioritized, and either are en- 
queued in individual ones of call queues 120 in their or- 
der of priority or are enqueued in different ones of a plu- 

40 rality of call queues that correspond to a skill and each 
one of which corresponds to a different priority. Like- 
wise, each agent's skills are prioritized according to his 
or her level of expertise in that skill, and either agents 
are enqueued in individual ones of agent queues 1 30 in 

45 their order of expertise level or are enqueued in different 
ones of a plurality of agent queues that correspond to a 
skill and each one of which corresponds to a different 
expertise level. Included among the control programs in 
ACD system 101 are a call vector 140, and a function 

50 for estimating in-queue waiting time (EWT) 145. Calls 
incoming to the call center on lines or trunks 100 are 
assigned by call vector 140 to different call queues 
121-129 based upon the agent skill that they require for 
their proper handling. A call may require more than one 

55 skill, and hence may be assigned to multiple call queues 
121-129 simultaneously, typically at different priorities. 
EWT 145 computes estimates of how long an incoming 
call will have to wait in a call queue 121-1 29, e.g., before 
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being handled by an agent. Agents 106-108 who are 
available for handling calls are assigned to agent 
queues 131-139 based upon the skills which they pos- 
sess. An agent may have multiple skills, and hence may 
be assigned to multiple agent queues 1 31 -1 39 simulta- 
neously. Furthermore, an agent may have different lev- 
els of skill expertise (e.g., skill levels 1-16 in one known 
system or merely primary (P) skills and secondary (S) 
skills in another known system), and hence may be as- 
signed to different agent queues 1 31 -1 39 at different ex- 
pertise levels. Call vectoring is described in DEFINITY® 
Communications System Generic 3 Call Vectoring/Ex- 
pert Agent Selection (EAS) Guide, AT&T publication no. 
555-230-520 (Issue 3, Nov. 1993). Skills-based ACD is 
described in further detail in U. S. Patent no. 5,206,903. 
An illustrative E WT function is described in U. S. Patent 
no. 5,506,898. 

Conventionally, an agent 106-108 is assigned to 
one or more agent queues 1 31 -1 39 unconditionally up- 
on becoming available to handle a call, is assigned to 
each agent queue 131-139 that corresponds to one of 
the agent's skills, and is assigned to each such agent 
queue at a priority that corresponds to the agent's level 
of expertise in the corresponding skill. According to the 
invention, however, agent assignment to agent queues 
1 31 -1 39 is made conditional, based on the call-center's 
real-time conditions defined by the operator of the call 
center (also often referred to as the administrator or the 
supervisor or the owner of the call center, or the custom- 
er). For this purpose, the control programs of ACD sys- 
tem 101 include agent vectors 150, with at least one 
agent vector 156-158 for each agent 106-108, respec- 
tively. Agent vectors 1 50 and other control programs as- 
sociated therewith (e.g., vector programming support 
facilities) may be stored either in an internal memory of 
system 1 0 1 or in an external storage device (e.g. , a disk, 
a CD-ROM, etc.). Each agent vector 156-158 is a script, 
a program, that is executed when the corresponding 
agent 1 06-1 08 becomes free to handle a call (e.g., con- 
ventionally when the state of the corresponding agent 
106-108 becomes "available"). Further according to the 
invention, a scripting language is provided for compos- 
ing agent vectors 156-158. The commands and condi- 
tionsthat make upan illustrative example of the scripting 
language are diagramed in FIGS. 2-12 and 13-23, re- 
spectively, and are described below. 

"Wait_seconds hearingjn ACW if_" command of 
FIG. 2 gives the agent a "breather" from handling calls 
for the specified time if the specified condition is satis- 
fied. The command's parameters are: number of sec- 
onds; audio-program source number; and a condition. 
Upon encountering this command in an agent vector, at 
stop 200, ACD system 101 determines (computes) the 
specified condition, at step 202, and if the condition has 
not been satisfied, as determined at step 204, system i 
101 contin ues on to a next command of the agent vector, 
at step 222. If it is determined at step 204 that the spec- 
ified condition has been satisfied, system 101 proceeds 



to steps 210 et seq. to give the agent a "breather". At 
step 210, system 101 places the agent in the "after-call 
work" (ACW) state, to prevent the agent from receiving 
another call. It then connects the agent's audio to the 
audio source specified by the command's "hearing^" pa- 
rameter, at step 212. This may be, for example, an an- 
nouncement, or music, or silence. System 101 also 
starts a timer to time the "breather" time period whose 
length is specified by the command's "_seconds fl pa- 
> rameter, at step 21 4. System 1 01 then waits for this time 
period to expire, at step 216. Upon expiration of the 
"breather" time period, system 101 disconnects the 
agent from the audio source of step 212, at step 213, 
and places the agent back in the "available" state, at 
step 220. System 101 then continues on to a next com- 
mand of the agent vector, at step 222. 

"Wait_seconds hearingjn AUX reason code_if_" 
command of FIG. 3 gives the agent a "breather" or, when 
used together with a "goto" command, changes the type 
of work given to the agent, for up to the indicated time 
if the specified condition is satisfied. The command's pa- 
rameters are: number of seconds; audio-program 
source number; a reason code; and a condition. Upon 
encountering this command in an agent vector, at step 
300, ACD system 101 determines the specified condi- 
tion, at step 302, and if the condition has not been sat- 
isfied, as determined at step 304, system 101 continues 
on to a next command of the agent vector, at step 320. 
If it is determined at step 304 that the specified condition 
has been satisfied, system 101 places the agent in aux- 
iliary work (AUX) state, at step 306, to prevent the agent 
from receiving another call. It then starts a timer to time 
the "breather" or alternate-work time period whose 
length is specified by the command's "_ seconds" pa- 
rameter, at step 308. During this time period, the agent 
does not receive ACD calls. System 101 also indicates 
the code specified by the command's "reason code_" 
parameter to the agent and to CMS 110, at step 310. 
System 1 01 then also connects the agent's audio to the 
audio source specified by the command's "hearing," pa- 
rameter, at step 312. This may be a null source, i.e., 
silence. System 101 then waits for this time period to 
expire, at step 314. Upon expiration of this time period, 
system 101 disconnects the agent from the audio 
source of step 312, at step 316, and places the agent 
back in the "available" state : at step 318. System 101 
then continues on to a next command of the agent vec- 
tor, at step 320. 

"Playjone" command of FIG. 4 plays a specified 
tone to the agent in order to get the agent's attention. 
The command's parameter is a tone identifier. (For ex- 
ample, if the EWT of a call queue being served by the 
agent exceeds some predetermined time, an urgency 
tone may be played to the agent to alert the agent that 
he or she needs to be unusually efficient in handling 
calls.) Upon encountering this command in an agent 
vector, at step 400 : system 101 briefly plays the tone 
specified by the Mone" parameter to the agent, at step 
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402. System 101 then continues on to a next command 
of the agent vector, at step 404. 

"Announcement extension^ command of FIG. 5 
plays the specified announcement to the agent. The 
command parameter is an announcement identifier. Up- 
on encountering this command in an agent vector, at 
step 500, system 101 connects the agent's audio to the 
indicated announcement, at step 502. When the an- 
nouncement is done playing, as determined at step 504, 
system 101 disconnects the agent's audio from the an- 
nouncement, at step 506, and continues on to a next 
command of the agent vector, at step 508. 

Take direct agent call if_" command of FIG. 6 con- 
nects the agent to any call that was placed directly to 
the agent's own telephone number (as opposed to the 
ACD telephone number) if the specified condition is sat- 
isfied. The command's parameter is: an indication of a 
condition that must be satisfied for the command to be 
executed. Upon encountering the command in an agent 
vector, at step 600, system 101 determines the condi- 
tion, at step 602, and if the condition is not satisfied, as 
determined at step 604, system 101 continues on to a 
next command of the agent vector, at step 614. If it is 
determined at step 604 that the condition is satisfied, 
system 101 checks whether there is a dircct-agent call 
enqueued for this agent, at step 606. (Direct-agent calls 
are treated by ACD system 101 like ACD calls, but are 
assigned to, and queued at, the highest priority level.) 
If a direct-agent call is enqueued for this agent, system 
101 dequeues the oldest direct-agent call for this agent 
and connects it to the agent, at step 608. System 101 
then ends processing of this agent vector, at step 610. 
If it is determined at step 606 that a direct -agent call for 
this agent is not enqueued, system 101 assigns the 
agent to the direct-agent (highest-priority) queue 
131-139, at step 612, to await the arrival of a direct- 
agent call for this agent. System 101 then continues on 
to a next command of the agent vector, at step 614. 

"Take call from skill_expertise leveUf_" command 
of FIG. 7 places the agent in the agent queue associated 
with the specified skill and expertise level if the specified 
condition is satisfied. The command's parameters are: 
a skill number; an expertise-level number; and a condi- 
tion that must be satisfied for the command to be exe- 
cuted. Upon encountering the command in an agent 
vector, at step 700, system 101 determines the condi- 
tion, at step 702, and if the condition is not satisfied, as 
determined at step 704, system 101 continues on to a 
next command of the agent vector, at step 714. If it is 
determined at step 704 that the condition is satisfied, 
system 101 checks whether the call queue that corre- 
sponds to the skill specified by the command's "skill_" 
parameter has an enqueued call, at step 706. If so, sys- 
tem 101 dequeues the highest-priority oldest-waiting 
call from that call queue and connects it to the agent, at 
step 708. System 101 then ends processing of this 
agent vector, at step 710. If it is determined at step 706 
that a call is not enqueued in the call queue specified by 



the command's "skilL" parameter, system 101 en- 
queues the agent in the agent queue 1 31 -1 39 which cor- 
responds to the skill specified by the command's "skilL" 
parameter, at step 71 2, to await the arrival of a call need- 

s ing that skill. System 101 then continues on to the next 
command of the agent vector, at step 714. 

"Consider skill_expertise level_if and "Take call 
from all considered" are commands that effectively func- 
tion as one command. Their functionality is shown in 

10 FIGS. 8 and 9, respectively. These commands connect 
the agent to the call with the greatest need from all con- 
sidered call queues. Typically, there will be two or more 
"consider" commands in sequence in an agent vector, 
followed by the "take cair command. The "consider" 

is commands function as specifiers of call queues for the 
"take call 0 command, which functions as the operator. 
The parameters of the "consider" command are: a skill 
number; an expertise-level number; and a condition. 
Upon encountering the "consider" command in an 

20 agent vector, at step 800, system 101 determines the 
condition, at step 802, and if the condition is not satis- 
fied, as determined at step 804 : system 101 continues 
on to a next command of the agent vector, at step 814. 
If it is determined at step 804 that the condition is satis- 

25 fjed, system 101 checks whether there is a call en- 
queued in the call queue that corresponds to the skill 
specified by the command's "skill_" parameter, at step 
806. If not, system 101 records this determination, at 
step 81 2; if so, system 101 determines the priority of the 

30 highest-priority calls that are enqueued in that call 
queue, at step 808, and then determines the age of the 
oldest one of those highest-priority enqueued calls, at 
step 810. System 101 then records this determination, 
at step 812. Following step 812, system 101 continues 

35 on to a next command of the agent vector, at step 814. 
Upon encountering the "take call from all consid- 
ered" command in an agent vector, at step 900, system 
101 retrieves the recorded determination of all immedi- 
ately-preceding "consider" commands, at step 902, and 

40 determines therefrom whether there are any calls wait- 
ing in the call queues for which the "consider" com- 
mand's conditions were satisfied, at step 904. If there 
are no waiting calls, system 101 enqueues the agent in 
the agent queues that correspond to the call queues of 

45 step 904, at step 906, and then continues on to a next 
command of the agent vector, at step 908. If it is deter- 
mined at step 904 that there are waiting calls, system 
101 determines from the recorded determinations the 
highest-priority oldest enqueued call, at step 910. Sys- 

50 tern 101 then dequeues this call from its call queue and - 
connects it to the agent, at step 912, and then ends 
processing of this agent vector, at step 914. 

"Goto step_if_" command of FIG. 10 redirects 
agent-vector execution to a specified step in the agent 

55 vector if the specified condition is satisfied. The com- 
mand's parameters are: an identifier of a particular step 
(command) in the agent vector; and a condition that 
must be satisfied for the command to be executed. Upon 
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encountering the command in an agent vector, at step 
1 000, system 1 01 determines the specified condition, at 
step 1002, and if the condition is not satisfied, as deter- 
mined at step 1004, system 101 continues on to a next 
command of the agent vector, at step 1006. If it is de- 
termined at step 1004 that the specified condition is sat- 
isfied, system 1 01 continues execution of the agent vec- 
tor at the vector step specified by the "step_ M parameter, 
at step 1008. 

"Goto agent vector_if_" command of FIG. 11 redi- 
rects vector execution to the specified agent vector if the 
specified condition is satisfied. The command's param- 
eters are: an identifier of an agent vector; and a condi- 
tion. Upon encountering this command in an agent vec- 
tor, at step 1 1 00, system 1 01 determines (computes) the 
specified condition, at step 1102, and checks whether 
the specified condition is satisfied, at step 1104. If not, 
system 1 01 merely continues on to a next command of 
the agent vector, at step 1 106; if so, system 101 ceases 
execution of Ihe agent vector thai it is presently execut- 
ing and commences execution of the agent vector spec- 
ified by the "agent vector_" parameter, at step 1 1 08. The 
agent remains enqueued in any agent queues in which 
he or she has been enqueued. 

"Route to agent vector_if_" command of FIG. 1 2 de- 
letes the agent from agent queues 130 and redirects 
vector execution to a specified agent vector if a specified 
condition is satisfied. The command's parameters are: 
an identifier of an agent vector; and a condition. Upon 
encountering this command in an agent vector, at step 
1200, system 101 determines (computes) the specified 
condition, at step 1202, and checks whether the speci- 
fied condition is satisfied, at step 1204. If not, system 
101 merely continues on to a next command of the agent 
vector, at step 1210; if so, system 101 deletes the agent 
from ail agent queues 131-139, at step 1206, and then 
ceases execution of the agent vector that it is presently 
executing and commences execution of the agent vec- 
tor specified by the "agent vector_" parameter, at step 
1208. 

"If new call skill_pri_ewt (comp)_" condition of FIG. 
1 3 tests if the expected in-queue waiting time of a new 
call just entering a specified call queue meets a speci- 
fied time limit. The condition's parameters are: a skill 
number; a skill priority number; a comparator (comp); 
and an estimated in-queue waiting time limit. Allowed 
comparators are "less than", "greater than", "less than 
or equal to", "greater than or equal to", "equal to", and 
"not equal to". Upon encountering this condition in a vec- 
tor command, at step 1300, ACD system 101 obtains 
the EWT for a call of priority "pri_" in call queue of u skill_ M 
from EWT function 1 45, at step 1 302, and compares the 
obtained EWT against the specified limit by using the 
specified comparator, at step 1304. If the comparison is 
true, as determined at step 1 306, the condition has been 
satisfied, as indicated at step 1 308; if the comparison is 
false, the condition has failed, as indicated at step 1 31 0. 

"If oldest call waiting skill_prL(comp)_ H condition of 



FIG. 14 tests if the oldest presently-waiting call of the 
specified priority in a specified call queue meets a spec- 
ified time limit. The condition's parameters are: a skill 
number; a skill priority number; a comparator (comp); 
5 and a time limit. Upon encountering this condition in a 
vector command, at step 1400, ACD system 101 deter- 
mines the waiting time of the oldest call of priority "pri_" 
waiting in call queue of "skill_", at step 1402, and com- 
pares the waiting time against the specified time limit by 
10 using the specified comparator, at step 1404. If the com- 
parison is true, as determined at step 1406, the condi- 
tion has been satisfied, as indicated at step 1408; if the 
comparison is false, the condition has failed, as indicat- 
ed at step 1410. 
15 "If calls queued skilLpn_(comp)_" condition of FIG. 
15 tests if the number of presently-waiting calls of the 
specified or a higher priority in a specified call queue 
meets a specified limit. The condition's parameters are: 
a skill number; a priority number; a comparator (comp); 
20 and a limit number. Upon encountering this condition in 
a vector command, at step 1500, ACD system 101 de- 
termines the number of calls of priority "pri_" that are in 
call queue of "skiJI_", at step 1502, and compares this 
number against the specified limit number by using the 
25 specified comparator, at step 1 504. If the comparison is 
true, as determined at step 1 506, the condition has been 
satisfied, as indicated at step 1 508; if the comparison is 
false, the condition has failed, as indicated at step 1510. 
"If my % calls for this skill (comp)_*' condition of FIG. 
30 1 6 tests if calls handled from the call queue specified by. 
this condition's accompanying command constitute a 
specified percentage of all calls handled by the agent. 
The condition's parameters are: a comparator (comp) 
such as = , >, or <; and a percentage limit. Upon encoun- 
35 tering this condition in a vector command, at step 1 600, 
ACD system 101 obtains from CMS 110 the number of 
calls from the subject call queue handled by the agent 
during the agent's present login session, at step 1604, 
and the total number of calls handled by the agent during 
40 the agent's present login session, at step 1606. System 
101 then computes therefrom the percentage of all calls 
handled by the agent that are from the subject call 
queue, at step 1608, and compares the computed per- 
centage against the specified limit by using the specified 
45 comparator, at step 1610. If the comparison is true, as 
determined at step 1612, the condition has been satis- 
fied, as indicated at step 1 61 6; if the comparison is false, 
the condition has failed, as indicated at step 1614. 
"If my % talk time for this skill (comp)J' condition of 
50 FIG. 17 tests if the agent's talk time (time actually con- 
nected to a call) on calls from the call queue specified 
by this condition's accompanying command constitutes 
a specified percentage of the agent's total talk time. The 
condition's parameters are: a comparator (comp) = , >, 
55 or <; and a percentage limit. Upon encountering this 
condition in a vector command, at step 1700, system 
101 obtains from CMS 1 1 0 the talk time of calls from the 
subject queue handled by the agent during the agent's 
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present login session, at step 1704, and the total talk 
time of all calls handled by the agent during the agent's 
present login session, at step 1706. System 101 then 
computes therefrom the percentage of total talk time 
spent by the agent on calls from the subject call queue, s 
at step 1708, and compares the computed percentage 
against the specified limit by using the specified compa- 
rator, at step 1710. If the comparison is true : as deter- 
mined at step 1712, the condition has been satisfied, as 
indicated at step 1716; if the comparison is false, the 10 
condition has failed, as indicated at step 1714. 

"If TOD is (day)_(start time)_to (end time)_ n condi- 
tion of FIG . 1 8 tests if it is a particular time on a particular 
day (e.g. , time for the agent's break on the agent's work- 
day). The condition parameters are: the day, the starting *s 
time, and the ending time. Upon encountering this con- 
dition in a vector command, at step 1800, ACD system 
1 0 1 determines the present day and time-of-day, at step 
1802, and determines therefrom if the present day 
matches the day specified by the "(day)_"parameler and 20 
also if the present time-of-day falls within the time range 
specified by the "(start time)_" and "(end time)J* param- 
eters, at step 1804. If so, the condition has been satis- 
fied, as indicated at step 1806; if not, the condition has 
failed, as indicated at step 1808. 2S 

"If agents in AUX reason code_skill_(comp)_" con- 
dition of FIG. 1 9 tests if the number of agents having a 
specified skill and who are in the AUX work state for a 
specified reason meet a specified limit. The condition 
parameters are: a reason code; a skill number; a com- 30 
parator (comp); and a number limit. Upon encountering 
this condition in a vector command, at step 1900, sys- 
tem 101 obtains from CMS 110 the number of agents 
who have the specified skill, whose present work state 
is AUX, and whose reason code is the specified reason 35 
code, at step 1902. System 101 then compares the ob- 
tained number against the specified limit by using the 
specified comparator, at step 1904. If the comparison is 
true, as determined at step 1 906, the condition has been 
satisfied, as indicated at step 1910; if the comparison is 40 
false, the condition has failed, as indicated at step 1 908. 

"If agents staffed skill_(comp)_° condition of FIG. 
1 2 tests if the number of logged-in agents having a spec- 
ified skill meets a specified limit. The condition's param- 
eters are: a skill number; a comparator (comp); and a 45 
number limit. Upon encountering this condition in a vec- 
tor command, at step 2000, system 101 obtains from 
CMS 110 the number of agents who are presently 
logged in with the specified skill, at step 2002, and com- 
pares the obtained number against the specified limit by so 
using the specified comparator, at step 2004. If the com- 
parison is true, as determined at step 2006, the condi- 
tion has boon satisfied, as indicated at step 2010; if the 
comparison is false, the condition has failed, as indicat- 
ed at step 2008. 55 

"If agents available in skill_(comp)_" condition of 
FIG. 21 tests if the number of presently-free and avail- 
able agents having a specified skill meets a specified 



limit. The condition's parameters are: a skill number; a 
comparator (comp); and a number limit. Upon encoun- 
tering this condition in a vector command, at step 2100, 
system 101 determines the number of agents who are 
presently enqueued in the agent queue that corre- 
sponds to the specified skill, at step 2102, and compares 
the determined number against the specified limit by us- 
ing the specified comparator, at step 2104. If the com- 
parison is true, as determined at step 2106, the condi- 
tion has been satisfied, as indicated at step 2110; if the 
comparison is false, the condition has failed, as indicat- 
ed at step 2108. 

"If agents in ACW skilL(comp)_" condition of FIG. 
22 tests if the number of agents who are enqueued in 
the after-call work of a specified skill meet a specified 
limit. The condition's parameters are: a skill number; a 
comparator (comp): and a number limit. Upon encoun- 
tering this condition in a vector command, at step 2200, 
system 1 01 obtains from CMS 1 1 0 the number of agents 
who are in the ACW state for the specified skill, at step 
2202, and compares this number against the specified 
limit by using the specified comparator, at step 2204. If 
the comparison is true, as determined at step 2206, the 
condition has been satisfied, as indicated at step 2210; 
if the comparison is false, the condition has failed, as 
indicated at step 2208. 

"Unconditional" condition of FIG. 23 always results 
in performance of the corresponding command, i.e., the 
condition is always satisfied. There are no parameters. 
Upon encountering this condition in a vector command, 
at step 2300, system 101 treat the condition as having 
been satisfied, as indicated at step 2302. 

FIG. 24 shows an illustrative practical agent vector 
that might be composed by using the above-described 
script. The steps of the vector are as shown below. The 
parentheticals indicate the corresponding steps of FIG. 
24. 

(2400) 

1. Goto step 11 if agents available in skill 9>5. 
(2402 : 2404) 

2. Wait 10 seconds hearing silence in ACW if new 
call skill 9 pri low ewt < 20. (2406 : 2408) 

3. Take call from skill 9 expert level 2 if my % talk 
time for this skill < 30%. (2410, 2412, 2414) 

4. Consider skill 1 expert level 6 if my % talk time 
for this skill < 20%. (2416) 

5. Consider skill 2 expert level 8 if my % talk lime 
for this skill < 20%. (2418) 

6. Consider skill 3 expert level 4 if my % talk time 
for this skill < 20%. (2420) 

7. Take call from all considered. (2422, 2424) 

8. Take call from skills if unconditional. (2426, 2428, 
2430) 

9. Take call from skill 7 if calls queued skill 7 pri med 
> 3. (2432, 2434, 2436) 

10. Goto step 3 if unconditional. (2438, 2440) 

11. Announcement extension 8223. (2444) 
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12. Wait 999 seconds hearing silence in AUX rea- 
son code 6 if unconditional. (2446, 2448, 2450) 

The reason code 6 in step 12 illustratively repre- 
sents "mail outs", in which case the announcement in 
step 11 is "Do mail outs". 

Of course, various changes and modifications to the 
illustrative embodiment described above will be appar- 
ent to those skilled in the art. For example, additional 
commands and conditions may be specified, such as 
ones that take account of special days, e.g., mother's 
day, Chinese new year, Christmas, etc. Also, the vectors 
need not execute on the ACD system itself, but rather 
may execute on an adjunct processor. Furthermore, use 
of the agent vectors is not limited for voice-call ACD sys- 
tems, but rather they may be employed to deliver any 
type of communications, e.g., multimedia calls, Internet 
calls and messages, e-mail, etc. Such changes and 
modifications can be made without departing from the 
spirit and the scope of the invention and without dimin- 
ishing its attendant advantages. It is therefore intended 
that such changes and modifications be covered by the 
following claims. 



Claims 
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An ACD system (1 01 ) for distributing calls for han- 
dling to available ones of a plurality of agents 
(106-108) in a call center, CHARACTERISED BY 30 

programmable means (1 56-1 58) for specifying, 
under programming control of an operator of 
the call center, any one of a plurality of condi- 
tions that is selected by the operator; 35 
means (150: FIGS. 13-23) responsive to an 
agent becoming available to handle a call while 
a call is waiting to be handled by an available 
agent, for determining whether a present state 
of the call center satisfies the condition speci- 40 
fied by the programmable means; and 
means (150: FIGS. 2-12) responsive to a de- 
termination that the condition is one of (a) sat- 
isfied and (b) not satisfied by the present state, 
for causing the available agent to handle the 4$ 
waiting call, and responsive to a determination 
that the condition is another of (a) satisfied and 
(b) not satisfied by the present stale, for caus- 
ing the available agent to perform a function 
other than handling the waiting call. so 



2. The system of claim 1 wherein: 

the programmable means comprise 
means for storing, under control of the operator, 
a vector (1 56) specifying the one condition and 
further specifying one of a plurality of alterna- 
tive functions that is selected by the operator; 



55 



and 

the causing means are responsive to a deter- 
mination that the condition is another of (a) sat- 
isfied and (b) not satisfied by the present state, 
for causing the available agent to perform the 
alternative function specified by the vector. 

The system of claim 1 wherein: 

the causing means are responsive to a deter- 
mination that the condition is another of (a) satisfied 
and (b) not satisfied by the present state, for caus- 
ing (210-21 4 or 306-31 2) the available agent to take 
a break from handling calls. 



4. The system of claim 1 wherein: 



the programmable means comprise 
a plurality of programmable means (156-158) 
each corresponding to a different agent and 
specifying any one of the plurality of conditions 
that is selected for the corresponding agent by 
the operator; and 

the determining means are responsive to an 
agent becoming available, for determining 
(204) whether the present state satisfies the 
condition specified by the programmable 
means that correspond to the agent who has 
become available. 



5. The system of claim 2 wherein: 



the stored vector (1 56) comprises a plurality of 
steps (2400-2450) each specifying a different 
condition, an alternative function to be per- 
formed by the agent if the condition is met, and 
either a different one of the steps or an exiting 
of the vector to be performed if the condition is 
not met; 

the determining means comprise 
vector-step executing means (101:150) for ex- 
ecuting the steps of the stored vector beginning 
with a first step in response to the agent becom- 
ing available, responsive to the present state 
satisfying the condition specified by a present- 
ly-executing step by indicating to the causing 
means that the condition is satisfied, respon- 
sive to the present state not satisfying the con- 
dition specified by the presently-executing step 
and the presently-executing step specifying a 
different one of the steps by executing the dif- 
ferent one of the steps, and responsive to the 
present state not satisfying the condition spec- 
ified by the presently-executing step and the 
presently-executing step specifying an exiting 
of the vector by indicating to the causing means 
that the condition is not satisfied; and 
the causing means are responsive to an indi- 
cation that the condition is satisfied for causing 
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the available agent to perform the alternative 
function specified by the vector step whose 
condition is indicated to have been satisfied, 
and responsive to an indication that the condi- 
tion is not satisfied for causing the available 5 
agent to handle the waiting call. 

6. The ACD system for a call center that has a plurality 
of call queues (121-129) each corresponding to a 
different one of a plurality of agent skills for queuing 10 
waiting calls that need an agent having the corre- 
sponding skill for their handling, wherein: 

the programmable means comprise 
programmable means for storing, under pro- is 
gramming control of an operator of the call cent- 
er, a plurality of agent vectors (156-158) each 
corresponding to a different agent and each 
specifying one of a plurality of conditions that 
is selected by the operator and one of a plurality 20 
of alternative functions that is selected by the 
operator; 

the determining means comprise 
means (150: FIGS. 13-23) responsive to an 
agent having at least one of the skills becoming 2s 
available to handle a call while a waiting call is 
enqueued in at least one queue corresponding 
to the at least one skill of the agent, for deter- 
mining whether a present state of the call center 
satisfies the condition specified by the agent 30 
vector that corresponds to the available agent; 
and 

the means for causing comprise 
means (150: FIGS. 2-12) responsive to a de- 
termination that the condition is not satisfied, 35 
for causing the available agent to handle the 
waiting call, and responsive to a determination 
that the condition is satisfied, for causing the 
available agent to perform the alternative func- 
tion specified by the agent vector that corre- 40 
sponds to the available agent instead of han- 
dling the waiting call. 

7. The system of claim 6 wherein: 

45 

the condition specified by the vector corre- 
sponding to the available agent is a threshold 
for a waiting time of a call in a queue; and 
the determining means determine (FIG. 13 or 
14) whether a present waiting time of a call in so 
the queue in which the waiting call is enqueued 
is exceeded by the threshold. 

8. The system of claim 6 wherein: 

55 

the condition specified by the vector corre- 
sponding to the available agent is a threshold 
for a percentage of a workload of the corre- 



sponding agent; and 

the determining means determine (FIG. 16 or 
1 7) whether handling of calls from the queue in 
which the waiting call is enqueued presently ex- 
ceeds the threshold percentage of the workload 
of the available agent. 

9. The system of claim 6 wherein: 

the alternative function specified by the vector 
corresponding to the available agent is either han- 
dling (FIG. 6, 7 or 9) of a call from a predetermined 
call queue or a function (FIG. 2, 3 or 12) other than 
handling of a call. 

10. A method of automatically assigning work to indi- 
vidual ones of a plurality of agents (106-108) ot a 
call center, CHARACTERISED BY the steps of: 

an operator of the call center programmably 
specifying (156-158) any one of a plurality of 
conditions that is selected by the operator; 
in response to an agent becoming available to 
handle a call while a call is waiting to be han- 
dled by an available agent, determining (150: 
FIGS. 1 3-23) whether a present state of the call 
center satisfies the condition specified by the 
operator; 

in response to a determination that the condi- 
tion is one of (a) satisfied and (b) not satisfied 
by the present state, causing (150: FIG. 6, 7 or 
9) the available agent to handle the waiting call; 
and 

in response to a determination that the condi- 
tion is another of (a) satisfied and (b) not satis- 
fied by the present state, causing (150: FIG. 2, 
3 or 1 2) the available agent to perform a func- 
tion other than handling the waiting call. 
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(54) Agent vectoring 

(57) An ACD system (101) is programmable by an 
operator of the ACD system to automatically change the 
work of a call center agent (106-108) in order to maxi- 
mize the agent's productivity and to provide a variety of 
work balanced with "breather" time in order to prevent 
agent burn-out. The conditions for changing the agent's 
work and the agent's alternative duties when the condi- 
tions are met are both programmed by the operator via 
a vectoring capability (150) of the ACD system and a 
scripting language for defining the vectors. When an 



agent becomes available to handle a call from a partic- 
ular call queue (121-129), the agent's corresponding 
vector is executed, and the conditions specified by the 
vector are checked against the present status of the call 
center to determine if they are met. If the conditions are 
not met, the agent is caused to handle a call from the 
particular call queue. But if the conditions are met, the 
agent is caused to perform a function specified by the 
vector, other than handing a call from the particular call 
queue, even though a call may be waiting for an avail- 
able agent in that call queue. 
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